AT9-98-038 PATENT

## WHAT IS CLAIMED IS:

1. An apparatus for self-initiated instruction issuing comprising an instruction queue operable for issuing at least one instruction to an execution unit, said queue including a plurality of entries, each queue entry having a first portion and a second portion, said first portion operable for storing a first link data value and said second portion operable for storing a first data value, and wherein said first data value in a first queue entry is set in response to a first link data value in a preselected second queue entry, and wherein at least one instruction is selected for issuing in response to a predetermined first data value in a corresponding queue entry.

- 2. The apparatus of claim 1 further comprising a rename register device coupled to said queue, said rename register device including a plurality of entries, each entry having a first portion operable for storing a pointer data value and a second portion operable for storing a validity data value, wherein each said pointer data value is associated with a corresponding queue entry, and wherein each said first link data value is set in response to said pointer data values and said validity data values.
- 1 3. The apparatus of claim 2 wherein each said rename register device entry 2 includes a third portion operable for receiving a plurality of operand tags, and wherein

2

3

5

6

2

AT9-98-038 PATENT

each said pointer data value is operable for selection in response to a preselected one
of said plurality of operand tags.

- 4. The apparatus of claim 3 wherein each said queue entry includes a third portion coupled to said rename register device for receiving a first one of said plurality of operand tags, and a fourth portion coupled to said rename register device for receiving a second one of said plurality of operand tags, wherein said first and second operand tags are associated with a dispatching instruction, and wherein said first operand tag is further associated with said first link data value.
- 5. The apparatus of claim 4 wherein said queue is operable for broadcasting a preselected first operand tag.
- 1 6. The apparatus of claim 5 further comprising a storage device operable for receiving said broadcasting of said first operand tag.

> 🔍

1

2

1

2

3

4

5

1

2

3

7. The apparatus of claim 6 wherein said storage device is coupled to said
rename register device, and wherein each said rename register device entry includes a
fourth portion operable for storing a second data value, said second data value being
operable for setting in response to said broadcast first operand tag.

- 8. The apparatus of claim 7 wherein said first data value is operable for setting in response to said second data value.
- 9. The apparatus of claim 6 further comprising comparison logic coupled to said storage device and said queue, said comparison logic operable for receiving said broadcast tag and each said second operand tag, wherein a corresponding first data value is operable for setting in response to a match between said broadcast tag and at least one second operand tag.
- 10. The apparatus of claim 2 wherein each said rename register device entry includes a includes a fourth portion operable for storing a second data value, said second data value being operable for setting in response to an issuing instruction.
- 1 11. The apparatus of claim 10 wherein said first data value is operable for setting 2 in response to said second data value.

AT9-98-038 PATENT

12. The apparatus of claim 4 wherein each said queue entry further comprises a fifth portion operable for storing a second link data value and a sixth portion operable for storing a second data value, and a seventh portion coupled to said rename register device for receiving a third one of said plurality of operand tags, said third operand tag being associated with said dispatching instruction, and wherein said third operand tag is further associated with said second link data value, and wherein said second data value in said first queue entry is set in response to a preselected second link data value in a third queue entry.

13. The apparatus of claim 12 wherein each said second link data value is set in response to said pointer data values and said validity data values.

1

2

3

4

5

6

7

1

2

| 1 |  |  |
|---|--|--|
| 2 |  |  |
| 3 |  |  |
| 4 |  |  |
| 5 |  |  |
| 6 |  |  |
| 7 |  |  |

14. A method of self-initiated instruction issuing comprising the steps of:

setting a predetermined data value in a first portion of a preselected first queue entry in a queue operable for storing a plurality of instructions for issuing to an execution unit, said queue including a plurality of entries, each entry being associated with an instruction for issuing, wherein said first queue entry is preselected in response to a first data value in a second portion of a preselected second queue entry; and

selecting for issuing an instruction associated with said entry containing said predetermined data value in said first portion in response to said predetermined data value.

- 15. The method of claim 14 further comprising the step of, if said dispatching instruction is a one-cycle piped instruction, storing a first queue pointer data value associated with said dispatching instruction in a first portion of an associated rename register entry, said rename register including a plurality of entries, wherein said queue pointer value associates said rename register entry and said preselected queue entry corresponding to said dispatching instruction, and wherein said second queue entry is selected in response to a second queue pointer value.
- 16. The method of claim 14 further comprising the step of setting said first data value in response to a source operand data value of said dispatching instruction.

2

3

4

5

1

2

3

| 1 | 17.     | The method of claim 15 wherein said step of setting said first data value is     |
|---|---------|----------------------------------------------------------------------------------|
| 2 | omitte  | d in response to a predetermined data value in said first portion of said rename |
| 3 | registe | er entry                                                                         |

18. The method of claim 14 further comprising the steps of:

if an issuing instruction is not a one-cycle piped instruction, broadcasting a target operand tag; and

setting said predetermined data value in said first portion of said preselected first queue entry in response thereto.

- 19. The method of claim 14 wherein said step of setting said predetermined data value in said first portion is in response to an issuing of an instruction associated with said second queue entry.
- 1 20. The method of claim 19 further comprising the step of, after a one-cycle 2 delay, setting a predetermined data value in a first portion of a rename register entry, 3 said rename register including a plurality of entries, said rename register entry being 4 associated with said issuing instruction.

2

3

4

1

2

3

4

5

6

7

- The method of claim 20 further comprising the step of setting said
  predetermined data value in a first portion of a preselected first queue entry in
  response to said predetermined data value in said first portion of said rename register
  entry.
  - 22. The method of claim 18 further comprising the step of, after a one-cycle delay following said broadcasting step, setting a predetermined data value in a first portion of a rename register entry, said rename register including a plurality of entries, said rename register entry being associated with said issuing instruction.
  - 23. The method of claim 18 further comprising the step of, for each dispatching instruction, storing a source operand tag in a third portion of each queue entry, and wherein said step of setting said predetermined data value in said first portion of said preselected first queue entry in response to said target operand tag further comprises the step of comparing said target operand tag and said source operand tag contained in said third portion of each queue entry, said predetermined data value set in each entry wherein a match occurs.
- 1 24. The method of claim 22 further comprising the step of setting said 2 predetermined data value in said first portion of a preselected first queue entry in

2

1

2

AT9-98-038 PATENT

| 3 | response to said predetermined data value in said first portion of said rename register |
|---|-----------------------------------------------------------------------------------------|
| 4 | entry.                                                                                  |

- 1 25. The method of claim 15 wherein said second queue pointer value is associated 2 with a source operand tag of said dispatching instruction.
  - 26. The method of claim 25 wherein said second queue pointer value corresponds to a queue entry of an instruction target operand tag matching said source operand.
  - 27. The method of claim 14 wherein said first data value comprises a link mask having a number of bits equal to a number of entries in said queue.
- The method of claim 14 wherein said step of setting said predetermined data value is in response to an issuing of an instruction associated with said second queue entry.

AT9-98-038 PATENT

A data processing system for self-initiated instruction issuing comprising:
 an input means for communicating a plurality of instructions;
 a dispatch unit coupled to said input means;

at least one execution unit coupled to said dispatch unit for receiving instructions communicated therefrom, each execution unit including a self-initiated instruction issue mechanism for receiving said instructions and issuing instructions to an execution logic circuit for execution, said self-initiated issue mechanism comprising:

an instruction queue operable for issuing at least one instruction to said execution unit, said queue including a plurality of entries, each queue entry having a first portion and a second portion, said first portion operable for storing a first link data value and said second portion operable for storing a first data value, and wherein said first data value in a first queue entry is set in response to a first link data value in a preselected second queue entry; and

a rename register device coupled to said queue, said rename register device including a plurality of entries, each entry having a first portion operable for storing a pointer data value and a second portion operable for storing a validity data value, wherein each pointer data value is associated with a corresponding queue entry, and wherein each first link data value is set in response to said pointer data values and said validity data values.

2

1

2

1

2

3

4

| 1 | The data processing system of claim 29 wherein each said rename register                  |
|---|-------------------------------------------------------------------------------------------|
| 2 | device entry includes a third portion operable for receiving a plurality of operand tags. |
| 3 | and wherein each said pointer data value is operable for selection in response to a       |
| 4 | preselected one of said plurality of operand tags.                                        |

- 31. The data processing system of claim 30 wherein said queue is operable for broadcasting a preselected first operand tag.
- 32. The data processing system of claim 31 further comprising a storage device operable for receiving said broadcast first operand tag.
  - 33. The data processing system of claim 32 wherein said storage device is coupled to said rename register device, and wherein each said rename register device entry includes a fourth portion operable for storing a second data value, said second data value being operable for setting in response to said broadcast first operand tag.
- 1 34. The data processing system of claim 33 wherein said first data value is 2 operable for setting in response to said second data value.
- 1 35. The data processing system of claim 32 further comprising comparison logic 2 coupled to said storage device and said queue, said comparison logic operable for

AT9-98-038 PATENT

receiving said broadcast tag and each said second operand tag, wherein a corresponding first data value is operable for setting in response to a match between said broadcast tag and at least one second operand tag.

- 36. The data processing system of claim 30 wherein each said rename register device entry includes a includes a fourth portion operable for storing a second data value, said second data value being operable for setting in response to an issuing instruction, and wherein said first data value is operable for setting in response to said second data value.
- 37. The data processing system of claim 30 wherein each said queue entry further comprises a fifth portion operable for storing a second link data value and a sixth portion operable for storing a second data value, and a seventh portion coupled to said rename register device for receiving a third one of said plurality of operand tags, said third operand tag being associated with said dispatching instruction, and wherein said third operand tag is further associated with said second link data value, and wherein said second data value in said first queue entry is set in response to a preselected second link data value in a third queue entry.